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1 INTRODUCTION 



Any user-system based on an 8 bit external bus • for example a micro- 
processor based usersystem - can be interfaced with the MDC controller, 
designed to simplify the D120/ D140 Disk Drive system connection. 

Adaptable to specific user systems the controller can operate as a slow 
buffered device, or as a rapid transfer device working in real time with, 
autonomous or external halt at the end of processing. 

Interfacing is simple - only 15 lines for data and control signals are re- 
quired. 



2 OPERATIONAL MODES 



Three different modes of operation have been designed into the controller, 
allowing a universal approach to different system architectures, and varied ' 
applications of the disk drives. These operational modes are discussed in 
detail in the following paragraphs. Throughout the remainder of the text, 
differences are noted where applicable. 



2.1 BUFFERED MODE 



For systems working with several peripheral devices, where a disk subsys- 
tem is accorded a low priority, this mode allows a slow, asynchronous 
data transfer into a memory buffer. Capacity of the buffer is 4 x 256 x 
9 bits (including a data integrity parity bit). This allows storage of up 
to 4 consecutive sectors, each sector containing a maximum of 256 data 
bytes (1 byte = 8 bits) 

Another application of the buffered mode is updating. In this case the 
buffer is addressed and partial updating can be effected without trans- 
ferring a block of complete sectors from the disk to the processor. 



2.2 REAL TIME MODE - AUTONOMOUS HALT 



As the name suggests, data is transferred at a rate of 916 Kbytes/second 
in real time in blocks of up to four sectors. After the processor initiates 
a read/write operation the controller executes the required operation and 
automatically halts when the specified number of sectors has been proces- 
sed. 



2.3 REAL TIME MODE - EXTERNAL HALT 



This operational mode is similar to the real time mode - autonomous 
halt, with a transfer rate of 916 Kbytes/second. However, the difference 
is in that the number of sectors to be processed is not specified. After the 
processor initializes a read/write command, the controller starts execution 
of the command and continues the required operation until a halt instruc- 
tion is received from the processor. 

As a result, it is possible to read a track several times, or, write a complete 
track. 
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The user system controller interface comprises 15 lines. These lines ; are 
described in detail in § 3.4 and shown schematically «n f.gures 3 and 4. 



3.1 INTERFACE LOADING 

Each of the 15 lines is terminated in 240 ohms to the + 5V power 
supply and 660 ohms to ground. A similar termination at the system 
end interface is recommended. Lines asserted by the Controller are dri- 
ven by an open collector driver, while «ines asserted by the system in- 
terface are received by a standard TTL gate device. 



3.2 INTERFACE LOGIC 

The logic used at the interface is negative TTL. Logic levels are defined 
hereunder : 

HIGH : from 2.8 v to 5.25 volts, which corresponds to logic zero, 
or not asserted. 



LOW : from v to 0.4 volts, which corresponds to logic one, 
ground asserted, or, asserted. 



or 



NOTE 

An asterisk following the signal name indicates that the 
signal is significant at low level. 



UNIDIRECTIONAL 




1 TO 5 TTL 



BIDIRECTIONAL 

USER 



+5V 
240, 



75451 

OR 
75452 



6 



660^. 
I iWW ) 



CABLE Z- 140n 



1 TO 5 TTL 



CONTROLLER 



75451 

OR 

75452 



+5V 



CONTROLLER 



240 a 



"1 



660 a 

r"lV W 



<3 
-D 



75451 

OR ' 

75452 



1 TO 5 TTL 



Figure 1. Interface Line loading 
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3.3 INTERFACE CONNECTOR 



Physical connection between the Controller and the user system is ensur- 
ed, by a 43 conductor flat cable. The standard CiiHB cable connector is 
shown in figure 2. Other connectors, type HE9 may also be accommoda- 
ted. 



Figures 3 and 4 contain the identification of each interface signal and 
the number of its connector pin. 



CiiHB CONNECTOR 

Pin No 
SIGNAL 



SIGNAL 



GROUND 




GND 

sa 

GND 
GND 
S12 
GND 
GND 



2 


1 


4 


3 


6 


S 


8 


7 


r 


1 


12 


11 


14 


13 


IE 


15 


18 


17 


20 


19 


22 


21 


24 


23 


26 


25 



VIEW ON FLAT CABLE 
ENTERING THE Cii HB CONNECTOR 



HE9 TYPE CONNECTOR 

NOTE Signal/pin allocation is the same as 
the CiiHB connector. Pins 25 and 
26 are not connected. 



Figure 2. Interface connector 
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3.4 INTERFACE LINES 



CONNECTOR PIN 




> 1 

»«'*■*'■ :-■■■ .■■■■■■>■■-■> ,,»■; 
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" _ ' 



-.:,,-■-.■ 

#^:v#f,^-: 2 3 



SIGNAL NAME 

- RESET* 

FLAG* 

DATA* 

DOT* 

STROBE* — 



.or 



— D2* 



— D3* 



— D4* 
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D6* 

D7* 



D8* 



■PARITY* 



— GROUND 
- — LINES 



SPARE 



CONNECTOR PIN 



■ 
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8 
7 

12 

14 
16 



18' 
20 
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24 
19 
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'• -i I 

o . 
.:oc 

o 

:>£ 

en 

Q • ". '■■ , J 
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23 
2 



Figure 3. Interface signals and pin Nos. - Buffered Mode 
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3.4.2 Real Time Mode interface lines 



CONNECTOR PIN 



1 

k • , v ( :.- 

- _ ■ 

8 

■ 

7 
2 
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Figure 4. Interface signals and pin. Nos. - Real Time Mode 
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3.5 SIGNAL LINES 



Interface lines fall into two categories - he I/O Bus 8 II nes and 5 
control lines (or 6 control lines with real t.me operation) - refer to the 
Slow no Sraqraphs for a full detailed description. Figure 5 below, show; 
hoT e P So P nnection between the interface lines and I the ^controller 
buffer and registers. When the contro ler n operat.ng in real t'me mode 
no buffer is required. The controller interface c.rcu.ts for th.s mode are 
shown in figure 6. 





PARITY 

I/O BUS < 

Dl - 08 

DOT 



STROBE 



DATA 




DATA 
BUFFER 

256 x 8 bits 
+ PARITY 



INSTRUCTION 

DECODER 

AND 
J REGISTERS 



STATUS 
REGISTER 



MULTIPLEXER 

AND 

DRIVERS 



c 



c 



:> 



FLAG 



DRIVERS 



RESET 



RECEIVERS 



Figure 5. Buffered controller interface circuits 
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I 



TO USER SYSTEM 




DATA STROBE-*- 



PARITY — • f 



I/O BUS <£; 

01 - 08 



00T 



COMMAND 
STROBE 



OATA 



8 LINES 



:> 
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MULTIPLEXER 

AND 
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Figure 6. Real Time controller interface circuits 
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3.5.1 Control Lines 
3.5.1.1 RESET* 



The RESET line is a computer interface originated, ground asserted con- 
trol. It is asserted by the computer for approximately 300 ms upon 
power up and may be asserted by the interface to unconditionally re- 
set the MDC. 



3.5.1.2 FLAG* 



The FLAG is an MDC originated, ground asserted control. When asserted, 
this signal informs the computer interface that the MDC requires service. 



3.5.1.3 DATA* 



3.5.1.4 DOT 4 



The DATA line is a computer originated ground asserted signal. When it 
is asserted, the I/O lines (D1 to D8) contain a data byte. When it is not 
asserted the I/O lines will contain either a command or the controller' 
status byte. .. 



The DOT line is a computer interface gererated, ground asserted signal. 
When asserted, it indicates that the direction of data transfer is to the 
MDC. When not asserted, the direction of data transfer is from the MDC. 



3.5.1.5 STROBE* or COMMAND STROBE 1 



The STROBE line is a computer interface generated, ground asserted si- 
gnal. When asserted, it indicates that information is being transferred. The 
type of information transferred depends on the operational mode : in 
buffered mode, the information is Data, Commands and Status ; in real 
time mode, only Commands or Status are transferred. This line should 
be asserted for a minimum of 0.4 and a maximum of 2.0 microseconds. 
The computer interface should not change the state of any other lines 
during the interval beginning 0.2 microseconds before assertion of STROBE 
and ending 0.2 microseconds after the release of STROBE. The release of STROBE 
is interpreted by the MDC as the completion of a transfer. 
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3.5.1.6 DATA STROBE* 



The DATA STROBE is an MDC originated ground asserted signal. When 
asserted in real time mode, it signifies that data is to be transferred to 
or from the MDC. 



3.5.1.7 PARITY* 



The PARITY is a bi-directional ground asserted line which carries the 
parity bit of the I/O Bus lines. This line is asserted if the number of 
logic ones on the I/O Bus is even. 



3.5.2 l/OBus:D1 - D8 



The I/O Bus comprises 8 lines, designated as D1 to D8, with D8 as the 
least significant bit. The Bus is bi-directional and ground asserted. 

Four different types of information may be transferred over I/O Bus, 
namely, read, write, command and status modes. Each mode is accom- 
panied by its own strobe and is determined by the states of the control 
lines, DATA and DOT. 



4 I/O BUS STATES 



Lines DATA, DOT determine the command state of the I/O Bus. The 
I/O Bus has 4 states : 

1 - READ DATA TRANSFER 

2 - WRITE DATA TRANSFER 

3 - COMMAND CONTROL 

4 - READ STATUS TRANSFER 

The truth table given below shows the logic conditions of the DATA and 
DOT lines and the state selected. Signal STROBE or COMMAND STROBE 
must also be present. 

Table 1. I/O Bus Table 



DATA STATE 


DOT STATE 


I/O BUS STATE 








READ STATUS 


® 


1 


CONTROL COMMAND 


1 





READ DATA 


( 1+ ) 


1 


WRITE DATA 
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4.1 STATUS MODE 



This mode requires DATA and DOT to be unasserted and causes the 
MDC to place status information on the I/O BUS. A strobe asserted in 
this mode is interpreted as a Read Status Strobe (RSS). 



4.2 COMMAND MODE 



This mode requires DOT asserted and DATA unasserted and causes the 
MDC to interpret the D lines as a command. D lines are examined 
only while STROBE is asserted. A strobe in this mode is interpreted as 
an Output Command Strobe (OCS). 



4.3 READ DATA MODE 



This mode requires DATA asserted and DOT unasserted and causes the 
MDC to place the currently held data byte on the I/O Bus. This data 
is valid in buffered mode during a data service request until the trailing 
edge of Read Data Strobe (RDS) is sensed by the MDC, and in real 
time mode during a data Strobe. 



4.4 WRITE DATA MODE 



This mode requires both DATA and DOT to be asserted and causes the 
MDC to interpret the D lines as a data word to be written (D lines are 
examined only while Write Data Strobe in buffered mode or Data Strobe 
in real time mode is asserted). 



5 COMMAND INSTRUCTIONS 



Table 2 lists all the commands that the controller will execute. 
To command the controller, the user system transfers the appropriate 
command instruction on the I/O Bus, asserts DOT and then strobes in 
with the STROBE or COMMAND STROBE line. 

To initiate a read or write operation the user system must transfer a 
command sequence of three consecutive bytes. 

Byte 1 gives the least seven significant bits of the track address where 
the operation is to start. Byte 2 identifies the two most significant bits 
of the track address and the head select. Byte 3 gives the six bit sec- 
tor address and whether the data is to be read or written. 



- 12 



MDC CONTROLLER - PRODUCT DESCRIPTION 



In each read or write operation, three consecutive commands instructions 
are necessary. 

Command bytes 1 and 2 are reserved for track and head addressing. 
Command byte 3 contai/is either a WRITE or READ Command, together 
with the sector address where the operation is to be performed. 

When the controller enters the BUSY state, the read/write commands - 
i.e., command with bit D1 = zero - are non-operational until the cur- 
rent operation is terminated. All other control commands (command 
with bit D1 = One) are normally executed. 

Table 2. Subsystem command set 



I/O BUS LINES 
D1 D2 D3 D4 D5 D6 D7 D8 



T2 T3 T4. T5 T6 T7 T8 



J3 NO N1 H1 T& T1 



& SS SO S1 S2 S3 S4 S5. 



Z 1 SO SI S2 S3 S4 S5 



1 1 



10 



10 10 



1 1 B6 B7 B8 B9 



1 1 1 B2 B3 B4 B5 



1 1 1 1 BO B1 



COMMAND 



TRACK SELECT - Selects track TT and prepares to 
enter the read or write mode 



TRACK SELECT - Selects track TT, the number of 
sectors NN to be- chained, and head H and prepares 
to enter the read or write mode subsequent to the 
next command. 



READ SECTOR SS - Moves on the previously selec- 
ted track and head, enters read mode, and reads data 
starting at sector SS. 



WRITE SECTOR SS - Moves on previously selected 
track and head, enters write mode and writes re- 
ceived data starting at sector SS. 



CLEAR DATA SERVICE - Resets the DATA SER- 
VICE and BUSY status bits. 



RESET - The controller and disk drive are uncon- 
ditionally reset. 



TERMINATE - this indicates the end of an opera- 
tion in read or write mode. 



BUFFER SELECT - Selects word BB in the control- 
ler buffer (lowest order bits). 



BUFFER SELECT - Selects word BB in the control- 
ler buffer. 



BUFFER SELECT - Selects word BB in the control- 
ler buffer (highest order bits). 



13 - 



MDC CONTROLLER - PRODUCT DESCRIPTION 



5.1 COMMANDS BYTE No. 1 

D1 



D8 






X 


X 


X 


X X 


X 


* 



t 



5.2 COMMAND BYTE No. 2 



bits 2 to 8 may be 1 or 0, 
and signify the seven low or- 
der bits of the track address. 

bit D1 is always 



D1 














D8 








N1 


N2 


D 


H 


TO 


Tl 



t ft * 



bits 7,8 may be 1 or 0. U' 
with bits 2-8 of command u/- 
te No. 1 allow addressing up 
to 511 tracks. 



head, select 



= upper head 

1 = lower head 



disk indentification 

gives the number of sectors 
to be processed -i.e., up to a 
maximum of four. These bits 
are not significant in real - time 
mode with external halt. 

always set to zero. 



5.3 COMMAND BYTE No. 3 

D1 






D8 



0/1 X X X X X X 



tt. 



bits D3-D8 give the starting sec- 
tor number where a read or write 
operation is to be performed. Bit 
D3 is the least significant bit. 

00 : indicates a read operation 

01 : indicates a write operation 
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5.4 SUBSYSTEM INITIALIZATION 



This command is required for unconditionally resetting the MDC. The 
memory buffer is not scratched, but the buffer address pointer is reset. 



Format : 
D1 D8 




1 | 




A ' "— ■^ — ' 


alwavs 




always 1 



5.5 CLEAR DATA SERVICE 



This command is required, during an up-dating operation effected in buf- 
fered mode, to unconditionally abort a read operation in the MDC. On 
the completion of this, commands DATA SERVICE and BUSY bits are 
reset. See also updating flowchart, figure 18. 

Format : 



D1 














D8 


1 








1 















5.6 DATA TRANSFER COMPLETE, or TERMINATE 



This command is sent in the buffered mode of operation to inform the 
MDC that no more data transfer cycles are required by the user-system. 
It is also sent in real time mode - external halt during the last sector 
being read or written in order to stop the data transfer. 



Format 
D1 



D8 



1 





1 
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5.7 BUFFER MEMORY ADDRESS 



The three commands described below are used in buffered mode only 
during an updating operation in order to set the buffer memory address. 
For further details, refer to the updating flowchart, figure 18. 




4 bits of buffer address - low 
order 

signifies 1st byte 

buffer address code 



Byte No 2 



D1 














D8 


1 


1 


1 


b 


B2 


B3 


B4 


B5 



.next four significant bits of 
buffer address 

signifies 2nd byte 



_ buffer address code 



Byte No 3 



D1 














D8 


1 


1 


1 


1 








BO 


B1 



.two most significant bits of buf- 
fer address 

.always zero 

.third byte code 

buffer address code 
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6 READ OPERATION 



For a read operation, the user-system performs the 3 byte command se- 
quence described in §5. If the controller is operating in buffered mode, 
it waits for the end of the operation, indicated by assertion of the 
FLAG line, and then initiates asynchronously, X bytes transfer from the 
controller buffer (with X value of 1 to N x 256, N being the number 
of sectors to be chained). See figure 7. 

If the controller is operational in real time mode, the buffer is by- 
passed and the data is transferred directly from the disk into the user- 
system. 



BUFFERED MODE READ SEQUENCE 





COMMAND 
SEQUENCE 


SEEK 
MOVEMENT 


SEARCH SECTOR 
AND SEAD 


READ BUFFER 
CYCLE 


END 
TRANS 


- DATA 
r ER 




HI 










BUSY 






— 






FLAG 




















LOAD BUFFER 


















^. 


1 BYTE 







Figure 7. Read operation - buffered mode 



REAL TIME MODE - READ SEQUENCE 






















DATA 
BUS 


pm 


V///////A 


BYTE 1 
READY 


BYTE 2 
READY 






BYTE 256 
READY 














DATA 
STROBE 




ST 1 


H 


— i r~ 

ST 256, 




COMMAND 
SEQUENCE 


HEAD POSITIONING, 
SEARCH SECTOR 






STRC 

f 


)BE DATA 
'ROCESSOR 


IN 





Figure 8. Read operation - real time mode 



17 - 



MDC CONTROLLER - PRODUCT DESCRIPTION 



7 WRITE OPERATION 



For a Write operation, the user system first performs the 3 byte com- 
mand sequence, as in the read operation and next initiates (asynchro- 
nously, if .the MDC is operating in buffered mode) an X bytes transfer 
into the Data Buffer, (with X = value of 1 to N x 258 ; N being the 
number of sectors to be chained) and then indicates the end of trans- 
fer with a TERMINATE command. If less than N x 256 bytes are 
transferred into the Data Buffer the remaining data field will be zero 
filled (see figures 9 and 10). 

After the FLAG line assertion indicating the end of operation, the user- 
system must read the Status Register to check that no error occurred 
in the disk sub-system during the operation. Refer f.o section 8 for* 
Status Register description. If the MDC is operating in real time mode, 
then the data is transferred synchronously with DATA STROBE to the 
MDC. See figure 11. 




OATA ZONE (filled by processor) 



} ZERO ZONE (filled by controller) 



Figure 9. Data buffer 



BUFFERED MOPE WRITE SEQUENCE 



COMMAND BUFFER LOADING, ENO OF OATA END OF HEAD 
SEQUENCE START SEEK TRANSFER POSITIONING 



BUSY 



FLAG 



li 



SEARCH SECTOR, 
WRITE DATA 



ULJl 



LOAD BUFFER 



Figure 10. Write operation - Buffered mode 
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REAL TIME MODE WRITE SEQUENCE 



















OATA 


■'//////, SB,* 


BYTE 
RFAm 


2 




BYTE 256 
RFAnY 


W///A 


BUS 














OATA 
STROBE 




ST 1 




|ST 2 \ $1 "g 












COMMAND 
SEQUENCE 


HEAD POSITIONING, 
SEARCH SECTOR 






STROBE DATA INTO 
CONTROLLER 



Figure 1 1 . Write operation - real time mode 



8 STATUS READ OPERATION 



The status of the subsystem can be read (sampled) at any time by the 
external control unit by monitoring the DATA and DOT lines. However, 
in order to properly reset the status lines that are transient, the compu- 
ter interface will usually pulse the strobe line after or during the samp- 
ling operation, generating an RSS. ( = DATA, DOT unasserted,followed 
by strobe). 

If the Write Count Error, the Fault Status, the Parity Error Status or 
the Read Error Status lines are set, they will be reset on the trailing 
edge of the Read Status Strobe pulse ; if one of the error bits is set 
after the leading edge of a RSS strobe, it will only be reset by the 
next RSS strobe in order to allow proper sampling operation. Figure 12 
shows the recommended timing of a status transfer. 



8.1 STATUS REGISTER 



The status register is used to store information comming from the disk 
subsystem. This information comprises three functional bits giving the 
operational status of the disk subsystem and five incident bits indicating 
fault conditions. 



bits D1 



D8 



BSF 


WCE 


FLT 


PER 


RER 


BSY, 


RDY 


DAS 



fault conditions 



operational states 



The eight bits are described in detail in § 8.2 
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Table 3. Status Register bits 



BSF 


WCE 


FLT 


PER 


RER 


BSY 


RDY 


DAS 



■ Data service 

. Disk is ready to seek, 
read or write 

.MDC is busy 

, Read error 

.Parity error 

. Disk subsystem err< 

Write count error 

.Bad sector found 



STATUS 
LINES 



DATA' 



DOT* 



RSS* 



4WM 


1 ft 1 

STATUS 

VALID 

(MAY CHANGE) 


ERROR 
STATUS 
BEING 

RESET • 


— * — i 

STATUS 

VALID 

(MAY '"MANGE) 
">1 


'% 

/ ///, 


, 


^ 


Y 
















'/////////, 




v //a 
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Figure 12. Status transfer timing 
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8.2 STATUS BITS 



8.2.1 BSF - Bad Sector Found 



Bad Sector status, bit D1, indicates that at least one sector which has 
been processed by the MDC is found defective. As a result, the opera- 
tion is aborted and the flag line is asserted in the case where the MDC 
does not process a bad sector saving operation. Refer to table 4. 

Table 4. BSF status 



OPERATIONAL 


MDC HANDLES 


FLAG LINE 


ABORT 


MODE 


SAVING OPERATION 


ASSERTED 


OPERATION 


BUFFERED 


YES 
Bad sector status may be 
permanently set to logic 
zero 


NO 


NO 


REALTIME 


YES 


NO 


NO 


INTERNAL 


Bad sector status may be 






HALT 


permanently set to logic 
zero 






REALTIME 








EXTERNAL 


NO 


YES 


YES 


HALT 









NOTE 

The BSF status is cleared by an RSS, by dispatching 
a reset command, or by asserting the RESET LINE. 



8.2.2 WCE - WRITE COUNT ERROR 



Write count status is set in buffered mode if more than N x 256 bytes (N being 
the number of sectors to be chained) are issued to the buffer and is 
indicated by the assertion of D2. This status is cleared by a Read Sta- 
tus Strobe pulse, by sending a Reset command or by asserting the re- 
set line. This bit is always set to logic zero in the real time operational 
mode. 
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8.2.3 FLT - Fault 



Fault status is indicated by the assertion of D3 and is set under the 
following conditions : 

• A failure of the disk to complete a search operation within approxi- 
mately 500 milliseconds. 

• A failure of the MDC to detect a sector pulse within 500 microse- 
conds. 

• A failure of the MDC to complete a read/write operation on the 
addressed sector within the period between two index pulses. 

• A failure of the MDC to detect a proper device clock signal. 

• A failure in the disk drive. 

Fault status is cleared by RSS, by issuing a reset command or by asser- 
ting the RESET line. 



8.2.4 PER - Parity Error 



Parity error status is indicated by the assertion of D4 and is set in the 
case of : 

• A failure to match the parity bit of the addressed sector written on 
the track recognition area of this sector and the parity bit of the 
track sector calculated in the MDC. This error may occur during a 
read/write operation. 

• A failure of the MDC to match the parity bit of a data byte written in the buf- 
fer and the parity bit of this data byte when read out of the buffer. This error 
may occur during a data transfer operation from the MDC buffer tc 
computer when in read mode and during a write operation into the uisk 
when in write mode. 

• A failure of the MDC to match the parity line and the parity of the 
8 bidirectional lines during an output command strobe, a write data 
strobe in buffered mode or a data strobe in real time mode write 
operations. 

Parity error status is cleared by RSS, by sending a Reset command, or 
by asserting the Reset line. 
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8.2.5 RER - Read Error 

Read error status is indicated by the assertion of D5 and is set : 

• When the data syncfield is not detected correctly 

• When the MDC had read and transferred a block of data and then 
finds that the Cyclic Redundancy Check characters at the end of the 
block do not agree with what it has calculated. 



8.2.6 BSY - Busy 



8.2.7 RDY - Ready 



Read error status is cleared by a read status strobe pulse, by sending a 
Reset command, or by asserting the Reset line. 



Busy status is indicated by the assertion of D6 whenever the Midi Disk 
Controller is in the Read or Write mode. 



Ready status is indicated by the assertion of D7 whenever a disk is in 
the drive, the door is closed, the disk is spinning at the specified rate 
and the heads have been positioned over a track. The Midi Disk Control- 
ler will delay a read/write operation until the Ready line is true. 



8.2.8 DAS - Data Service 



8.3 FLAG LINE 



The Data Service request is indicated by the assertion of D8 in buffered 
mode and occurs whenever data should be transferred. This line is clear- 
ed by the positive-going edge of either a Read Data Strobe pulse or 
a Write Data Strobe pulse depending on whether the system is reeding 
or writing, and by a Clear Data Service Command. This bit is always 
set to logic zero with the controller in real time mode of operation. 



The flag line is true when one of the following conditions exist : 

I.The Data Service status bit in buffered mode is true, indicating that 
data is ready to be transferred in either a read or write operation. 
Appropriate transfer of data (as signaled by a Write Data Strobe pulse 
or Read Data Strobe pulse) resets the Data Service bit. 

2. An error condition exists, caused by the rise of Bad Sector Found 
(if any), Write Count Error, Fault, Parity Error or Read Error. The 
assertion of the Flag line will allow the computer to fall through its 
data transfer. 

3. The busy line drops after a Terminate command is issued (while the 
system is in either the buffered read or write mode), and raises the 
computer/controller Flag line. The raising of this line signals to the 
external control unit that the MDC has completed writing the data 
in write mode or sensed an end of data buffer reading operation in 
Read mode. 
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The Flag line is reset by generating a Read Status Strobe, issuing a Re- 
set command or pulsing the Computer/Controller Reset line. 



9 DATA TRANSFER 
9.1 BUFFERED MODE 



The controller is said to be buffered because it includes a data buffer 
with a capacity of four sectors. 

When the system is in the Read mode, data is transferred from the 
disk to the buffer and then to the external control unit at any rate 
established by the external control unit ; the buffer might be read 
more than once by the CPU before a terminate command is issued. 

When the system is in Write mode, the external control unit transfi 
data to the buffer at any rate it desires. When the MDC receives a ter- 
minate command (the buffer is full), it automatically transfers the data 
into the disk. 

To end a write operation, the Terminate command is issued. When the 
subsystem ceceives this command, it immediately lowers the FLAG line 
and, if less than a full sector was transferred, fills out the sector with 
zero bytes and writes the CRC characters. 

Finally, it causes the FLAG line to go high to signal the completion of 
the write operation. 



DATA SERVICE (bit 08) 




NOTE : X • HOC processing time : 0.9 .US « X « 1.9 ,us. 

S • service time with no timing restrictions. Extern«1 control 
may leave the flag unserviced Indefinitely. 

Figure 13 . Data transfer timing - Buffered mode 
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Figure 13 illustrates the data transfer requirements. One byte is transfer- 
red at a time, where the external control unit is not required to res- 
pond within a specific time interval after the Flag goes true. Thus the 
external control unit can treat the system as a truly asynchronous de- 
vice. However, if the Read Data Strobe/Write Data Strobe frequency is 
fast enough, the buffer can be written or read with a maximum trans- 
fer rate of 916 Kbytes/secOnd. 



9.2 REAL TIME MODES 



Data transfer is synchronous with the disk and each data block consists 
of 256 bytes. Figure 14 gives the detailed timing for each byte ex- 
change during read or write operations. 



READ MODE 

I/O BUS | 



DATA VALID 



DATA STROBE 



4T 



3T 



WRITE MODE 



I/O BUS 

J 


V////S. 


DATA MUST BE VALID 


'mm 


DATA STROBE* 




. £ 100 n S> T >ioo ns 





















T « DISK DRIVE CLOCK PERIOD : 136 nsec. + 31 



Figure 14. Data transfer Timing - Real Time Mode 
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10 SECTOR FORMAT 



There are 392 tracks on each disk face with each track containing 48 
sectors in which data is formatted in blocks of 256 bytes. 

Data integrity is ensured by a longitudinal polynomial tx 16 + x 15 + x 2 + u 
used for cyclic redundancy checking (at the system interface level and 
in the buffer memory, data is checked by means of a lateral parity 
bit) 

Figure 15 illustrates the format for each sector. 



GAP 
10 bytes 
O's 



DATA SYNC. 

1 byte 

FD16 



DATA 
256 bytes 



CRC 
2 bytes 



POST AMBLE 
1 byte 
FF16 



GAP 



Figure 15. Sector format 



11 BAD SECTOR PROCESSING 



A disk cartridge is not defect-free ; consequently, the data blocks must 
not be recorded in the defective, or bad, sectors. Bad sectors are indic- 
ated at the device interface level by an appropriate signal. 

The system will be responsible for bad sector saving and management 
of the, retrieval operation. The MDC allows several possibilities of man- 
agement, outlined below. 



'11.1 BAD SECTOR MANAGEMENT - BUFFERED MODE 



Bad sector management is processed completely by the MDC (2 spare 
sectors are provided at the end of each track), and the user system 
ignores the disk defects. 

The Bad Sector Found status bit (BSF) may however be set by the 
MDC and used for logging purposes by the system. 
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11.2 BAD SECTOR MANAGEMENT - REAL TIME MODES 



In these modes of operation, bad sector management may be either 
processed by the MDC or taken over by the user system. 



• MDC Management 

Each defective sector is saved in the immediate following sector. In this 

case, the MDC must wait for an INDEX pulse prior to beginning a 

read/write operation, giving a read/Write latency time of 8.33 msec 
(half disk revolution). 

The Bad Sector Found (BSF) status bit may, however be set by the 
MDC and used for system logging. 

• System Management 

In this case, when the MDC detects a defective sector it immediately 
aborts the current read/write operation. It then asserts the Flag line to 
allow the system to stop the data transfer and sets the BSF status bit. 
The system then initiates its own save operation. The total number of 
sectors available is 50 per track (with a maximum number of two 
being defective). 



12 READ/WRITE OPERATION FLOWCHARTS 



Figure 16 illustrates a typical operation sequence in buffered mode. 
Note, there are no timing restrictions and that it is not necessary to 
wait for a valid CRC error status at the end of a read transfer. Figure 
17 illustrates a typical operational sequence in real time modes. If an 
error occurs, the FLAG line remains asserted until the corresponding 
error status is reset. 



13 SECTOR UPDATING OPERATION FLOWCHART 



To update the data content of N sectors (with N < 4) the user sys- 
tem issues a read command sequence (three commands), waits for the 
FLAG line to go high and resets it with the CLEAR DATA SERVICE 
command. 

Next, the user system dispatches a write command sequence, waits for 
the FLAG line and then sends the three command sequence for buffer 
addressing. This selects the starting buffer word and initiates "X" num- 
ber of transfers to the buffer (X words updated, with X as value, from 
1 to 256). Finally, the computer sends the Terminate command, waits 
for the assertion of the FLAG line and checks if the operation was 
done correctly. A flowchart illustrating an updating operation is shown 
in figure 18. 

- 27 - 




Figure 16. Read/write operation flowchart - buffered mode 
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Figure 17. Read/write operation flowchart - real time mode 
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Figure 18. Sector updating flowchart - buffered mode 
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